package com.xie.leetcode.array;

//575. 分糖果
//        给定一个偶数长度的数组，其中不同的数字代表着不同种类的糖果，每一个数字代表一个糖果。你需要把这些糖果平均分给一个弟弟和一个妹妹。返回妹妹可以获得的最大糖果的种类数。
//
//        示例 1:
//
//        输入: candies = [1,1,2,2,3,3]
//        输出: 3
//        解析: 一共有三种种类的糖果，每一种都有两个。
//        最优分配方案：妹妹获得[1,2,3],弟弟也获得[1,2,3]。这样使妹妹获得糖果的种类数最多。
//        示例 2 :
//
//        输入: candies = [1,1,2,3]
//        输出: 2
//        解析: 妹妹获得糖果[2,3],弟弟获得糖果[1,1]，妹妹有两种不同的糖果，弟弟只有一种。这样使得妹妹可以获得的糖果种类数最多。
//        注意:
//
//        数组的长度为[2, 10,000]，并且确定为偶数。
//        数组中数字的大小在范围[-100,000, 100,000]内。

import java.util.HashMap;
import java.util.Map;

/**
 * @author xiezhendong
 * @date 2021/11/1
 */
public class DistributeCandies {

    public static void main(String[] args) {
        DistributeCandies distributeCandies = new DistributeCandies();
        System.out.println(distributeCandies.distributeCandies(new int[]{1, 1, 2, 2, 3, 3}));
        System.out.println(distributeCandies.distributeCandies(new int[]{1, 1, 2, 3}));
    }

    public int distributeCandies(int[] candyType) {
        int num = candyType.length / 2;
        Map<Integer, Integer> candyTypeMap = new HashMap<>();
        for (int i : candyType) {
            candyTypeMap.merge(i, 1, Integer::sum);
        }
        return Math.min(candyTypeMap.keySet().size(), num);
    }
}
